Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: rust std::backtrace #4274

Merged
merged 2 commits into from
Sep 19, 2023
Merged

feat: rust std::backtrace #4274

merged 2 commits into from
Sep 19, 2023

Conversation

jowparks
Copy link
Contributor

@jowparks jowparks commented Sep 7, 2023

Summary

Currently we have no backtrace when an error occurs in rust. This makes debugging in javascript and ironfish-rust-nodejs very challenging. This PR uses std::backtrace to include backtrace info into the returned error information.

If we include debug info with our profile:

RUST_BACKTRACE=1 yarn test:slow                                                                                                                                                                     yarn run v1.22.19
$ jest --testPathIgnorePatterns --testMatch "**/*.test.slow.ts"
 FAIL   @ironfish/rust-nodejs  tests/demo.test.slow.ts
  ● Demonstrate the Sapling API › Should create a standard transaction

    InvalidBalance
    Backtrace:
       0: std::backtrace_rs::backtrace::libunwind::trace

      at ../../../../../rustc/90743e7298aca107ddaa0c202a4d3604e29bfeb6/library/backtrace/src/backtrace/libunwind.rs:93:5
         1: std::backtrace_rs::backtrace::trace_unsynchronized
      at ../../../../../rustc/90743e7298aca107ddaa0c202a4d3604e29bfeb6/library/backtrace/src/backtrace/mod.rs:66:5
         2: std::backtrace::Backtrace::create
      at ../../../../../rustc/90743e7298aca107ddaa0c202a4d3604e29bfeb6/library/std/src/backtrace.rs:332:13
         3: ironfish::errors::IronfishError::new
      at ../ironfish-rust/src/errors.rs:61:24
         4: ironfish::transaction::ProposedTransaction::post
      at ../ironfish-rust/src/transaction/mod.rs:221:28
      5: ironfish_rust_nodejs::structs::transaction::NativeTransaction::post
      at src/structs/transaction.rs:293:34
      6: ironfish_rust_nodejs::structs::transaction::__napi_impl_helper__NativeTransaction__8::__napi__post::{{closure}}::{{closure}}
      at src/structs/transaction.rs:167:1
         7: napi::bindgen_prelude::within_runtime_if_available
      at ../../../.cargo/registry/src/github.com-1ecc6299db9ec823/napi-2.13.2/src/lib.rs:171:5
      8: ironfish_rust_nodejs::structs::transaction::__napi_impl_helper__NativeTransaction__8::__napi__post::{{closure}}
      at src/structs/transaction.rs:167:1
         9: core::result::Result<T,E>::and_then
      at ../../../../../rustc/90743e7298aca107ddaa0c202a4d3604e29bfeb6/library/core/src/result.rs:1372:22
      10: ironfish_rust_nodejs::structs::transaction::__napi_impl_helper__NativeTransaction__8::__napi__post
      at src/structs/transaction.rs:167:1
      at Object.<anonymous> (tests/demo.test.slow.ts:131:65)

 PASS   @ironfish/rust-nodejs  tests/transaction.test.slow.ts

Test Suites: 1 failed, 1 passed, 2 total
Tests:       1 failed, 8 passed, 9 total
Snapshots:   0 total
Time:        3.774 s, estimated 4 s
Ran all test suites.
error Command failed with exit code 1.
info Visit https://yarnpkg.com/en/docs/cli/run for documentation about this command.

If we don't include debug for our release profile:

RUST_BACKTRACE=1 yarn test:slow
yarn run v1.22.19
$ jest --testPathIgnorePatterns --testMatch "**/*.test.slow.ts"
 FAIL   @ironfish/rust-nodejs  tests/demo.test.slow.ts
  ● Demonstrate the Sapling API › Should create a standard transaction

    InvalidBalance
    Backtrace:
       0: std::backtrace_rs::backtrace::libunwind::trace

      at ../../../../../rustc/90743e7298aca107ddaa0c202a4d3604e29bfeb6/library/backtrace/src/backtrace/libunwind.rs:93:5
         1: std::backtrace_rs::backtrace::trace_unsynchronized
      at ../../../../../rustc/90743e7298aca107ddaa0c202a4d3604e29bfeb6/library/backtrace/src/backtrace/mod.rs:66:5
         2: std::backtrace::Backtrace::create
      at ../../../../../rustc/90743e7298aca107ddaa0c202a4d3604e29bfeb6/library/std/src/backtrace.rs:332:13
         3: ironfish::transaction::ProposedTransaction::post
      4: ironfish_rust_nodejs::structs::transaction::NativeTransaction::post
      5: ironfish_rust_nodejs::structs::transaction::__napi_impl_helper__NativeTransaction__8::__napi__post
      at Object.<anonymous> (tests/demo.test.slow.ts:131:65)

If RUST_BACKTRACE isn't set:

yarn test:slow
yarn run v1.22.19
$ jest --testPathIgnorePatterns --testMatch "**/*.test.slow.ts"
 FAIL   @ironfish/rust-nodejs  tests/demo.test.slow.ts
  ● Demonstrate the Sapling API › Should create a standard transaction

    InvalidBalance
    To enable Rust backtraces, use RUST_BACKTRACE=1

      129 |     transaction.output(newNote)
      130 |
    > 131 |     const postedTransaction = new TransactionPosted(transaction.post(key.publicAddress, 100n))
          |                                                                 ^
      132 |
      133 |     expect(postedTransaction.expiration()).toEqual(10)
      134 |     expect(postedTransaction.fee()).toEqual(5n)

      at Object.<anonymous> (tests/demo.test.slow.ts:131:65)

 PASS   @ironfish/rust-nodejs  tests/transaction.test.slow.ts

Testing Plan

Documentation

Does this change require any updates to the Iron Fish Docs (ex. the RPC API
Reference
)? If yes, link a
related documentation pull request for the website.

[ ] Yes

Breaking Change

Is this a breaking change? If yes, add notes below on why this is breaking and
what additional work is required, if any.

[ ] Yes

@jowparks jowparks changed the base branch from master to staging September 7, 2023 17:53
@jowparks jowparks force-pushed the feat-rust-std-backtrace branch from 7cf9360 to 27fe18f Compare September 7, 2023 18:44
Cargo.toml Show resolved Hide resolved
@jowparks jowparks force-pushed the feat-rust-std-backtrace branch 7 times, most recently from 5672547 to 913d10c Compare September 9, 2023 00:07
@jowparks jowparks changed the title Feat rust std backtrace feat: rust std::backtrace Sep 9, 2023
@jowparks jowparks marked this pull request as ready for review September 9, 2023 00:09
@jowparks jowparks requested a review from a team as a code owner September 9, 2023 00:09
@jowparks jowparks force-pushed the feat-rust-std-backtrace branch 2 times, most recently from 78bc8d9 to d00f15a Compare September 9, 2023 00:21
@jowparks jowparks force-pushed the feat-rust-std-backtrace branch from d00f15a to d7411c0 Compare September 15, 2023 16:32
@jowparks jowparks force-pushed the feat-rust-std-backtrace branch from d7411c0 to debcb5f Compare September 15, 2023 16:35
ironfish-rust/src/transaction/mints.rs Outdated Show resolved Hide resolved
ironfish-rust/src/transaction/mints.rs Outdated Show resolved Hide resolved
@jowparks jowparks merged commit f8353b6 into staging Sep 19, 2023
@jowparks jowparks deleted the feat-rust-std-backtrace branch September 19, 2023 22:42
patnir added a commit that referenced this pull request Oct 2, 2023
* Add creator field to transaction api calls (#4254)

* Explicitly set the asset `creator` field of mints in `RawTransaction`

Do not assume that a mint will be done by the same account that created
the asset, but rather get the creator as an input.

This is necessary to enable minting of assets that you own but you have
not created.

* fixes wallet.updateHead test to be independent of fixture generation (#4265)

the test of updateHead fails when fixtures are regenerated, but passes if they
already exist

this is because creating an account may update the wallet's chainProcessor head
state, but importing an account does not
(https://linear.app/if-labs/issue/IFL-1585/createaccount-and-importaccount-inconsistent)

fixes test to pass indpendently of fixture generation by always updating the
wallet head to the genesis block before adding more blocks

* When an unknown asset is seen in a wallet transaction, backfill its information from the chain db before processing the transaction

This commit is purely a refactor of the current wallet logic, and should
not alter the user-visible behavior of the wallet in any way. This
refactor is foundational work needed to support the transfer of asset
ownership (via `transferOwnershipTo`) in the future.

What this commit does, in a nutshell, is that it makes the backfilling
code run before the transaction gets processed:

    before this change: account.addPendingTransaction(...) -> backfill assets
     after this change: backfill assets -> account.addPendingTransaction(...)

This will greatly simplify the processing of mints with
`transferOwnershipTo` inside `addPendingTransaction`.

* Add more information to getBlockResponse (#4217)

* feat(cli,ironfish): Return native asset when streaming wallet assets (#4267)

* feat(cli,ironfish): Return native asset when streaming wallet assets

* test(ironfish): Fix account test

* test(ironfish): Fix account test

* Add a consensus parameter for asset ownership

Add logic for the miners fee transactions to create the correct version

mining manager only accepts transactions into blocks with the correct
version for the given sequence

add v2 support to RawTransaction (#4234)

* add v2 support to RawTransaction

* add error if transferOwnershipTo exists on a v1 transaction

check the transaction version when adding blocks

This no longer checks the version when transactions are broadcast. This
is because there isn't an easy way to verify any particular version is
correct. A transaction could become valid due to a re-org or a consensus
parameter activating at a specific block sequence.

set devnet activation to 1

fixtures

use an optimistic transaction version when creating transactions (#4237)

* use an optimistic transaction version when creating transactions

This allows for transactions created around the time that a transaction
version change to have an improved chance of being included in the
blockchain by choosing the version if its within a range near the
current head sequence instead of simply choosing the transaction version
based on head sequence + 1

* clarify `versionSequenceDelta`

- Now takes `number` instead of `number | undefined` for a parameter
- Adds an assert to ensure a non-negative integer
- Add more comments + clarify existing
- Updated tests
- Increased the min delta to 4, since 3 is probably too small to ensure
  transactions aren't dead on arrival

remove hardcoded transaction version const (#4240)

* remove hardcoded transaction version const

* add `TransactionVersion::latest()`

mempool removes transactions with versions that should no longer be valid (#4249)

* Update the blockchain db whenever a mint with `transferOwnershipTo` is seen

When a `MintDescription` with `transferOwnershipTo` is seen, the
relevant asset on the chain db is updated to reflect the new owner.

* Update the wallet db whenever a mint with `tranferOwnershipTo` is seen

This also fixes a bug where minting a brand new asset and using it to
send tokens to an account in the same wallet would throw an exception.

* Track originating peer for block gossip (#4270)

* Make activation flag nullable (#4277)

* Make activation block nullable

* Update unit test

* Use a new type

* Add (de)serialization for `Asset`

* Add transferOwnershipTo support to CLI/RPC (#4278)

* adding use account endpoint (#4280)

* Rahul/ifl 1625 renameaccount endpoint (#4279)

* adding renameAccount endpoint

* rename account endpoint fixture

* Rahul/ifl 1587 createaccount endpoint (#4268)

* Adding create account endpoint to the wallet namespace

* changing endpoint name in rpc client

* moving request and response to the correct file

* updating comments

* adding remove account endpoint (#4281)

* adding remove account endpoint

* updating comment for remove

* Rahul/ifl 1603 make asset response consistent across all endpoints (#4272)

* new burn asset response with asset object

* updating tests

* moving asset to a types file to be reused in mint and burn

* updating test

* adding two different construct rpc methods

* updating RcpAccountAssetBalanceDeltaSchema

* updating get account transactions

* deprecating asset variables in balance endpoints

* removing asset object when id doesn't guarantee asset object is found

* removing optional asset object

* removing unused variable

* removing construct functions

* removing optional asset object

* deprecating asset name fields in note, mint, and burn

* normalizing rpc asset object for all endpointS

* fixing tests

* using asset value object

* adding back GetAssetResponse

* reverting client ts changes

* show n/a if supply is not available

* chain get asset uses same asset model

* using Assert.isNotUndefined(accountAsset)

* deprecating the status field on the asset

* adding comment

* removing expect

* Resetti9ng fixture

* sequential-block-time -> staging (#4276)

* [BlockTime] Update block verification to only allow positive block mine time (#4113)

* Update block verification

* Update consensus

* Update unit test

* add comma

* Update fixture

* Set sequential block mine time to never for testnet and mainnet

* Patched Fix Inefficient Regular Expression Complexity Regular Expression Denial of Service (#4271)

Affected of this project are vulnerable to Regular Expression Denial of Service (ReDoS) due to the usage of an insecure regular expression within the result variable.

```js
const wrap = require("word-wrap"); for (let i = 0; i <= 10; i++) { const attack = "a" + "t".repeat(i * 10_00000); const start = performance.now(); wrap( attack, { trim: true }, ); console.log(`${attack.length} characters: ${performance.now() - start}ms`); }
```
Denial of Service (DoS) describes a family of attacks, all aimed at making a system inaccessible to its original and legitimate users. There are many types of DoS attacks, ranging from trying to clog the network pipes to the system by generating a large volume of traffic from many machines (a Distributed Denial of Service - DDoS - attack) to sending crafted requests that cause a system to crash or take a disproportional amount of time to process.

CWE-1333
`CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L`

Co-authored-by: jowparks <[email protected]>
Co-authored-by: Rohan Jadvani <[email protected]>

* Rahul/ifl 1580 normalize encrypted note (#4285)

* new burn asset response with asset object

* updating tests

* moving asset to a types file to be reused in mint and burn

* updating test

* adding two different construct rpc methods

* updating RcpAccountAssetBalanceDeltaSchema

* updating get account transactions

* deprecating asset variables in balance endpoints

* removing asset object when id doesn't guarantee asset object is found

* removing optional asset object

* removing unused variable

* removing construct functions

* removing optional asset object

* deprecating asset name fields in note, mint, and burn

* updating note response types for chain endpoints

* fixing get block endpoint

* combining rpc note and wallet note

* Resetting gettransactionstream

* removing rpc note

* Resetting gettransactionstream

* favoring hash over noteHash

* resetting wallet types

* New fixture for multiple custom transactions (#4287)

* Rahul/ifl 1576 normalize block header (#4286)

* new burn asset response with asset object

* updating tests

* moving asset to a types file to be reused in mint and burn

* updating test

* adding two different construct rpc methods

* updating RcpAccountAssetBalanceDeltaSchema

* updating get account transactions

* deprecating asset variables in balance endpoints

* removing asset object when id doesn't guarantee asset object is found

* removing optional asset object

* removing unused variable

* removing construct functions

* removing optional asset object

* deprecating asset name fields in note, mint, and burn

* updating note response types for chain endpoints

* fixing get block endpoint

* combining rpc note and wallet note

* Resetting gettransactionstream

* removing rpc note

* Resetting gettransactionstream

* favoring hash over noteHash

* resetting wallet types

* adding rpc blockheader type

* setting up block header to be reused in chain

* consolidating block responses with transactions

* all tests pass

* removing hex

* changing the notesize back to null

* work was on the wrong endpoint, added back to follow chain stream

* removing work

* removing use of BigIntUtils.writeBigU256BE

* Rahul/ifl 1578 normalize transaction (#4288)

* new burn asset response with asset object

* updating tests

* moving asset to a types file to be reused in mint and burn

* updating test

* adding two different construct rpc methods

* updating RcpAccountAssetBalanceDeltaSchema

* updating get account transactions

* deprecating asset variables in balance endpoints

* removing asset object when id doesn't guarantee asset object is found

* removing optional asset object

* removing unused variable

* removing construct functions

* removing optional asset object

* deprecating asset name fields in note, mint, and burn

* updating note response types for chain endpoints

* fixing get block endpoint

* combining rpc note and wallet note

* Resetting gettransactionstream

* removing rpc note

* Resetting gettransactionstream

* favoring hash over noteHash

* resetting wallet types

* adding rpc blockheader type

* setting up block header to be reused in chain

* consolidating block responses with transactions

* all tests pass

* removing hex

* changing the notesize back to null

* work was on the wrong endpoint, added back to follow chain stream

* removing work

* normalizing rpc account transaction

* changing to wallet transaction

* removing extra transaction field

* renaming to account

* resetting chaintypes.ts

* resetting chaintypes.ts

* combining notes and spends

* adding comment about available notes and spends

* Making confirmations a deprecated field

* Use Decimal library to make feeRates deterministic (#4282)

* Rahul/ifl 266 mintasset and burnasset do not accept a feerate in requests (#4289)

* adding feerate to mintassets and burnassets

* changing to inline if

* making fee optional

* Rahul/ifl 1636 normalize block (#4295)

* adding block

* normalizing block

* removing dependency from deprecated field

* making burn create mint send account field optional (#4291)

* Rahul/ifl 1579 normalize transaction sub objects - mints and burns (#4293)

* creating and using rpc mint and burn everywhere

* compiling version

* Removing deprecated comment

* removing newline

* moving set fields up

* Rahul/ifl 1579 normalize transaction sub objects updating mint burn asset endpoints (#4294)

* creating and using rpc mint and burn everywhere

* compiling version

* using rpc mint for mint asset endpoint

* using rpc burn for burn asset endpoint

* asset mint and burn test

* merging staging and removing duplicate objects

* updating wallet types to staging file

* Add links to CI jobs on badges (#4296)

* Adding the Inversed Tech audit PDF report (#4184)

* resets account heads and birthdays in reset command (#4269)

* Increase the default difficulty when creating genesis and devnet difficulty (#4246)

* Increase the default difficulty when creating genesis

This is mostly useful for local devnet testing, as the default
difficulty is too easy for many systems, which results in transactions
not getting picked up from the mempool when testing locally due to the
pre-emptive empty block changes in the mining manager.

* fixtures

* Close streaming requests at the end of tests (#4090)

* Rahul/ifl 1651 add ability to show usage of deprecated fields in ironfish (#4298)

* adding ability to show usage of deprecated fields

* turning it off to pass lint check

* adding comment

* updated lockfile

* adding lint:deprecated

* feat: rust std::backtrace (#4274)

* feat: rust backtrace support for IronfishError

* pr review updates

* Export network definitions (#4302)

* marking counts fields as deprecated (#4301)

* Rahul/ifl 1641 add optional serialized field to transaction rpc (#4299)

* adding optional serialized field and required signature field

* adding serialized to endpoint input

* using options object instead of individual optional fields

* using question mark notation instead of question mark

* fixing merge issue

* Rahul/ifl 1665 normalize exportchainstream (#4304)

* adding optional serialized field and required signature field

* adding serialized to endpoint input

* reusing blockheader

* using options object instead of individual optional fields

* using question mark notation instead of question mark

* fixing merge issue

* creating single version of peer response (#4305)

* adding burns and mints to the account transaction (#4307)

* changing account transaction to wallet transaction (#4309)

* Notify Slack of fixture regeneration failure (#4164)

* Fix fixture regeneration failures for diable wallet test (#4310)

* Fix fixture regeneration failures for diable wallet test

* regnerate

* Rahul/ifl 1653 update gettransaction response to use the rpc transaction (#4300)

* adding optional serialized field and required signature field

* adding serialized to endpoint input

* updating getTransaction to use RpcTransaction

* passing test

* adding full transaction object to burn and mint asset response (#4311)

* formatting all rpc objects in the same order (#4313)

* formatting all rpc objects in the same order

* changing rcp to rpc

* removing id

* updating export chain stream

* standardizing array usage

* using [] instead of array

* Asset verification field in get balance

* rearranging get balances

* replacing array with []

* replacing array with []

* Rahul/ifl 1643 update cli to stop using the deprecated fields (#4315)

* updating balance command to use asset endpoint

* Returning asset id

* fetching asset for balance

* formatting fixes

* using sequence instead of seq

* updating wallet note deprecated comment

* removing deprecated field usage in wallet transactions and asset utils

* fixed deprecated usage in wallet transaction command

* reverting eslint to staging

* stylistic improvement to use destructing

* updating field name

* using forloop for more readable code

* cleaner lookup logic

* reverting to older balances version

* explicity type

* moving function in file

* removing new lines

* improving readability

* asset lookup helper function

* usign asset lookup helper function

* using helper in transactinos function

* using helper in transactinos function

* choice asset name

* Resume snapshot downloads if supported (#4308)

* Don't use streaming endpoint in status CLI (#4312)

* Rahul/ifl 1690 remove dependence on deprecated status field (#4320)

* Adding comment

* Removing use of deprecated status field

* Removing newline

* Removing unused variable

* removed status from asset wallet command

* Adding feerate to mint and burn (#4318)

* Handle socket read/write errors

* version bump 1.9.0 to 1.10.0 (#4326)

* running rust version bump

* removing new line

---------

Co-authored-by: mat-if <[email protected]>
Co-authored-by: Andrea Corbellini <[email protected]>
Co-authored-by: Hugh Cunningham <[email protected]>
Co-authored-by: lovedret <[email protected]>
Co-authored-by: Rohan Jadvani <[email protected]>
Co-authored-by: Mat <[email protected]>
Co-authored-by: Daniel Cogan <[email protected]>
Co-authored-by: ygao76 <[email protected]>
Co-authored-by: wica-sufatmawati <[email protected]>
Co-authored-by: jowparks <[email protected]>
Co-authored-by: Elena Nadolinski <[email protected]>
Co-authored-by: Derek Guenther <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants